<template>
  <el-card class="page-home">
    <template #header>后台首页</template>
    <!-- 卡片 -->
    <div class="card-list df jcsb">
      <card-vue
        :item="item"
        v-for="item in cardData"
        :key="item.title"
      ></card-vue>
    </div>
    <div class="myChart" ref="chartRef"></div>
  </el-card>
</template>

<script>
import {getOrderTotalReq} from '@/api/order'
import CardVue from './Card.vue'
//引入echarts
import * as echarts from 'echarts'
export default {
  components: {
    CardVue,
  },
  data() {
    return {
      cardData: [],
    }
  },
  methods: {
    async getData() {
      let res = await getOrderTotalReq()
      //解构数据
      let {
        xData,
        orderData,
        amountData,
        totalOrder,
        totalAmount,
        todayOrder,
        totayAmount,
      } = res.data
      //处理数据
      let temp = [
        {
          title: '总订单',
          count: totalOrder,
          imgUrl: require('@/assets/imgs/t1.png'),
        },
        {
          title: '总销售额',
          count: totalAmount,
          imgUrl: require('@/assets/imgs/t2.png'),
        },
        {
          title: '今日订单数',
          count: todayOrder,
          imgUrl: require('@/assets/imgs/t3.png'),
        },
        {
          title: '今日销售额',
          count: totayAmount,
          imgUrl: require('@/assets/imgs/t4.png'),
        },
      ]
      //数据赋值
      this.cardData = temp
      //处理数据
      let series = [
        {
          type: 'line',
          name: '金额数据',
          data: amountData,
        },
        {
          type: 'line',
          name: '订单数据',
          data: orderData,
        },
      ]

      this.renderLine({
        series,
        xData,
      })
    },
    //画折线图
    renderLine(obj) {
      // 初始化echarts实例
      let myChart = echarts.init(this.$refs.chartRef)
      //配置项
      let options = {
        title: {
          text: '数据统计',
        },
        tooltip: {
          trigger: 'axis',
        },
        legend: {},
        grid: {
          left: '3%',
          right: '4%',
          bottom: '3%',
          containLabel: true,
        },
        toolbox: {
          feature: {
            saveAsImage: {},
          },
        },
        xAxis: {
          type: 'category',
          boundaryGap: false,
          data: obj.xData,
        },
        yAxis: {
          type: 'value',
        },
        // series: [
        //   {
        //     name: "Email",
        //     type: "line",
        //     stack: "Total",
        //     data: [120, 132, 101, 134, 90, 230, 210],
        //   },
        //   {
        //     name: "Union Ads",
        //     type: "line",
        //     stack: "Total",
        //     data: [220, 182, 191, 234, 290, 330, 310],
        //   },
        // ],
        series: obj.series,
      }
      // 绘制图表
      myChart.setOption(options)
    },
  },
  created() {},
  mounted() {
    this.getData()
  },
}
</script>

<style lang="scss" scoped>
.page-home {
  height: 100%;
  background: #f0f2f5;
}

.myChart {
  margin-top: 50px;
  height: 300px;
  background: white;
}
</style>
